<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    table {
      border: 1px solid #000;
      text-align: center;
      width: 240px;
    }
    th,td {
      border: 1px solid #000;
    }
    h3 {
      position: relative;
    }
  </style>
</head>
<body>
  <!-- 计算属性 -->
   <!-- 概念：基于现有的数据，计算出来的新属性，依赖的数据变化，自动重新计算
    语法：
    1.声明在computed配置项中，一个计算属性对应一个函数
    2.使用起来和普通属性一样使用{{计算属性名}}
    计算属性->可以将一段求值的代码进行封装 -->
    <div id="app">
      <h3>小黑的礼物清单</h3>
      <table>
        <tr>
          <th>名字</th>
          <th>数量</th>
        </tr>
        <tr v-for="(item, index) in list" :key="item.id">
          <td>{{ item.name }}</td>
          <td>{{ item.num }}个</td>
        </tr>
      </table>
  
      <!-- 目标：统计求和，求得礼物总数 -->
      <p>礼物总数：{{totalCount}} 个</p>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script>
    <script>
      const app = new Vue({
        el: '#app',
        data: {
          // 现有的数据
          list: [
            { id: 1, name: '篮球', num: 1 },
            { id: 2, name: '玩具', num: 2 },
            { id: 3, name: '铅笔', num: 5 },
          ]
        },
        computed: {
          totalCount() {
            //基于现有的数据，编写求值逻辑
            //计算属性函数内部，可以直接通过this访问到app实例
            //需求：对this.list数组里面的num进行求和->reduce
            let total = this.list.reduce((sum, item) => sum + item.num, 0)
            return total
          }
        }
      })
    </script>
</body>
</html>